rest接口会返回各种各样的数据,如果对接口的格式不加约束,很容易造成混乱。
在实际项目中,一般会把结果放在一个封装类中,封装类中包含http状态值,状态消息,以及实际的数据。这里主要记录两种方式:(效果如下)
1、采用Map对象作为返回对象。
/** * Http请求接口结果封装方法 * * @param object 数据对象 * @param msgSuccess 提示信息(请求成功) * @param msgFailed 提示信息(请求失败) * @param isOperate 是否操作类型(增、删、改) * @return */ public static Map<String, Object> getResponse(Object object, String msgSuccess, String msgFailed, boolean isOperate) { Map<String, Object> data = new HashMap<>(); if (object != null) { data.put("success", true); data.put("msg", msgSuccess); data.put("result", 1); } else { data.put("success", false); data.put("msg", msgFailed); data.put("result", 0); } if (!isOperate) { data.put("data", object); } else { data.put("data", null); } return data; }
2、根据不同类型结果,调用不同的封装方法。
/** * 格式化请求结果(List类型) * * @param <T> * @param objectList 对象列表 * @param msgSuccess 信息提示(请求成功) * @param msgFailed 信息提示(请求失败) * @return */ @SuppressWarnings("unchecked") public static <T> Tb_Response<T> getResponse(List<T> objectList, String msgSuccess, String msgFailed) { Tb_Response<T> tb_Response = new Tb_Response<T>(); if (objectList.size() > 0) { tb_Response.setSuccess(true); tb_Response.setMsg(msgSuccess); tb_Response.setResult(1); tb_Response.setData((List<T>) objectList); } else { tb_Response.setSuccess(false); tb_Response.setMsg(msgFailed); tb_Response.setResult(0); } return (Tb_Response<T>) tb_Response; } /** * 格式化请求结果(Object类型) * * @param <T> * @param object 对象信息 * @param msgSuccess 信息提示(请求成功) * @param msgFailed 信息提示(请求失败) * @return */ @SuppressWarnings("unchecked") public static <T> Tb_ResponseData<T> getResponseData(T object, String msgSuccess, String msgFailed) { Tb_ResponseData<T> tb_ResponseData = new Tb_ResponseData<T>(); if (object != null) { tb_ResponseData.setSuccess(true); tb_ResponseData.setMsg(msgSuccess); tb_ResponseData.setResult(1); tb_ResponseData.setData((T) object); } else { tb_ResponseData.setSuccess(false); tb_ResponseData.setMsg(msgFailed); tb_ResponseData.setResult(0); tb_ResponseData.setData(null); } return (Tb_ResponseData<T>) tb_ResponseData; } /** * 格式化请求结果(Boolean类型) * * @param result 请求结果 * @param msgSuccess 信息提示(请求成功) * @param msgFailed 信息提示(请求失败) * @return */ public static Tb_ResponseData<Boolean> getResponseData(boolean result, String msgSuccess, String msgFailed) { Tb_ResponseData<Boolean> tb_ResponseData = new Tb_ResponseData<Boolean>(); if (result) { tb_ResponseData.setSuccess(true); tb_ResponseData.setMsg(msgSuccess); tb_ResponseData.setResult(1); } else { tb_ResponseData.setSuccess(false); tb_ResponseData.setMsg(msgFailed); tb_ResponseData.setResult(0); } tb_ResponseData.setData(null); return tb_ResponseData; }